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VIRTUAL PAGE PRINTING OF INDICIA* LOGOS AND GRAPHICS 

FIELD OF THE INVENTION 

The present invention relates generally to systems and methods for printing indicia, logos 
and graphics and more particularly to systems and methods for printing postal indica on 
envelopes. 

BACKGROUND „ , _ . 

Metered postage is a significant source of revenue for the United States Postal Service 

(USPS) Meteredpostageisgenemtedby^ 

known as postal indicia, on mail pieces- Generally, printing postage or any value-bearing items 
(VBI) may be accomplished with mechanical meters or computer-based systems. ^ 
With respect to computer-based postage processing systems, the USPS under the 
information-based indicia program (IMP) has published specifications for IBIP postage meters. 
The 1BIP involves the development of new technology to produce new forms of postage fa so- 
called PC postage systenis, a user can purcr^e postage ^ 

of PC postage onto a label or directly onto a mail piece. The PC postage includes a human 
readablTportion,anindiciagraprucandatwodimension^^ The human readable 

portion includes the postage value, mail class, the date, the meter number, the licensing post 
Office m,t a user registered with, an optional logo a^^ 

(required for business courtesy mail pieces.) The barcode portion is intended to heh^hw^ 
fraud, and includes information about the mail piece including the destination ZIP code, *e 
amount of postage applied, the date and time the postage was applied, the meter number and a 
digital signature so that the USPS can validate the authenticity of the postage. _ 

The USPS mail automation process utilizes various scanning machines when sorting the 
mail. Therefore, postage indicia must be printed in a prescribed manner to permit the mail 
handlina and optical reading equipment to properly interpret me PC postage and addresse 
information. Indeed, the USPS has established strict guidelines directed to the margins, label 
sizes, and placement of the postage indicia, as well as the size, placement^ and other 
characteristics of the POSTNET (PQStal Numeric Encoding lechnique) ^ 
facing identification mark (FIM) on mail pieces. These guidelines arecont^ed inme Domesuc 
Mail Manual (DMM) and Title 39, Code of Federal Register (CFR), Part HI,. and USPS 
Publication No. 25 "Designing Letter Mail". . 

To ensure that a mail piece can be properly scanned, the mail p.ece needs to be oriented 
in a pre-defined manner. Proper orientation of the mail piece is facilitated by means of a F M 
barcode or a phosphorescent strip, one of which should be included pn each piece o» d 
mail. However, a FiM in the form of a phosphorescent strip typically requires the use ofa 
specialized envelope or label, since standard printers are unable to print a phosphorescent strip. 
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I RefemngtoFIG.I,aFIMbarcode8ontheom^ 

in the upper right area of a mail piece. Advantageously, the FIM barcode may be printed using 
the ink from a standard ink jet or laser jet printer. Therefore, indicia-based postage can penetrate 
the mainstream mass-market more easily with a FIM barcode solution. 
5 A FIM barcode is essentially a nine-bit code consisting of bars and spaces (no-bar place 

holders) in which the bars corresponding to a binary one and spaces correspond to a binary zero. 
The FIM barcode 8 allows scanning machines to determine the orientation of individual mail 
pieces and the corners of both sides of the mail piece. Once the scanner has detennined where 
the FIM barcode is on the mail piece, the mail piece may be re-oriented so that the scanner can 
10 properly read the delivery information. 

The aforementioned USPS guidelines require the FIM pattern to be printed in a FIM clear 
zone, in which no other printing appears. The FIM clear zone is defined as a rectangular zone 
extending downwardly 0.625" from the upper edge of the mail piece and between 3.0" and 1.75". 
from the right hand edge of the mail piece. 
15 The guidelines further require the bars in the FIM barcode to be 0.625" ± 0.125" high and 

0 03 125" ± 0.008" wide. Referring to FIG. 2, the rightmost bar of the FIM barcode should be 2" 
±0 125" from the right edge of the mail piece. Thetopof the bars in the FIM barcode should 
be no lower than 0.125" from the top of the mail piece and the bottom of the FIM bars should 
touch the bottom edge of the FIM clear zone but must not be more than 0.125" above or below 

20 that edge. • , 

Standard printers typically do not support print margins of 0.125" or less. If anenvelope 
is fed to a printer long edge first, the distance from the FIM barcode to the edge is determined 
by the top margin of the print job created by the printer, which is typically well in excess of 
0 125" on standard ink jet and laser jet printers. Similarly, ifan envelope is fed to a printer short 
25 edge first, the distance from the FIM to the edge of the envelope is still determined by the top 
margin of the printer because the printer prints the envelope in landscape mode. Again, the top 
margin is typically greater than 0.125" on most printers Short edge feed is shown m the following 
diagram the distance from the FIM barcode to the edge is determined by either the left or nght 
side margin of the printer, which is also typically well in excess of 0.125" on most printers. 
30 The inability of most printers to comply with the tolerances set forth for FIM barcode 

location in the USPS automation system may require printing indicia based postage onto labels 
and/or envelopes with the FIM barcode pre-printed onto them. Therefore, it. would be 
advantageous to provide a method and system for printing text or graphics within tight edge 
constraints for use in postage systems that use a printer to print indicia-based postage. 
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SUMMARY OF THE INVENTION 

In one aspect of the present invention, a method for printing information onto an envelope 
includes generating a print job for a virilized sheet having an image of the information 
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I contained within a printable region of the virtuaiized sheet, and transmitting said print job for 
said virtuaiized sheet to a printer. 

In another aspect of the present invention, a method of printing postal indicia onto a print 
media includes determining a printer offset as a function of how the mail piece is fed into the 
5 printer, generating a print job for a virtuaiized sheet wherein an image of an envelope is located 
within a printable region of the virtuaiized sheet as a function of the printer offset and printing 
the postal indicia onto the mail piece. 

In a further aspect of the present invention a method for printing information onto a print 
media includes generating a print job for a virtuaiized sheet, wherein an image to be printed on 
1 0 the print media is located within a printable region of the virtuaiized sheet as a function of 
printing the image closer to one or more edges of the print media than otherwise allowed by a 
printer for the print media. 

In another aspect of the present invention a method for printing postal indicia onto 
envelopes includes generating a print job Tor a virtuaiized sheet having an image of the postal 
15 indicia located within a printable region of the virtuaiized sheet as a function of how the envelope 
is fed into a printer, performing a margins requirements test, and transmitting the print job to the 
printer to print the postal indicia as a function of the margin requirements test. The system may 
also rotate the envelope image as a function of the margin requirements test. 

In a further aspect of the present invention media that may be read by a computer 
20 embodies a program of instructions executable by a computer to perform a method for printing 
postal indicia onto an envelope, the method includes determining a printer offset as a function 
of how the envelope is fed into the printer, generating a print job for a virtuaiized sheet wherein 
an image of the postal indicia is located within a printable region of the virtuaiized sheet as a 
function of the printer offset and printing the postal indicia onto the envelope. 

25 

BRIEF DESCRIPTION OF THE DRAWINGS - 

These and other features, aspects, and advantages of the present invention will become 
better understood with regard to the following description, appended claims, and accompanying 
drawings where: 

30 FIG 1 is a plan view of an envelope with a barcode printed in accordance with USPS 

requirements in the upper right hand corner of the envelope; 

FIG. 2 is a plan view of an envelope demonstrating the USPS requirements for FIM 
barcode placement; 

FIG: 3 A is a block diagram of an Internet client/server environment used by an on-line 
35 postage system in one embodiment of the present invention; 

FIG. 3B is a simplified block diagram illustrating the table used in client and server based 
printer databases in accordance with an exemplary embodiment of the present invention; 

FIG. 4 is a capture of an exemplary print postage dialog screen for a single recipient in 
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1 accordance with an exemplary embodiment of the present invention; 

FIG. 5 is a capture of an exemplary print prompt screen that allows a user to edit the 
properties of the selected printer and decide whether to print sample or actual postage in 
accordance with an exemplary embodiment of the present invention; 
5 FIG. 6 is a capture of ah exemplary print postage dialog screen for multiple recipients in 

accordance with an exemplary embodiment of the present invention; 

FIG 7 is a capture of an exemplary envelope options screen in accordance with an 
exemplary embodiment of the present invention; 

FIG. i8 is a plan view of an envelope with a graphic included in the return address area in 
10 accordance with an exemplary embodiment of the present invention; 

FIG. 9 is a flow chart demonstrating a process for printing postal indicia on envelopes in 
accordance with an exemplary embodiment of the present invention; 

FIG. 10 is a plan view of an envelope demonstrating a virtualization process that re- 
formats an envelope print job into a print job for a virtual sheet of paper in accordance with an 
15 exemplary embodiment of the present invention; 

FIG. 1 1 demonstrates a page layout determining the printable region for a virtualized sheet 
in accordance with an exemplary embodiment of the present invention; 
FIG. 12 demonstrates envelope feed positions for a typical printer; 
FIG. 1 3 is a plan view of virtualized sheets demonstrating offsets of the printable region 
20 in accordance with an exemplary embodiment of the present invention; 

FIG. 14A is a plan view of an envelope with a FIM barcode printed in accordance with 
the USPS requirements which defines distinct sections between the right hand edge of the 
envelope and the FIM barcode in accordance with an exemplary embodiment of the present 
invention; 

25 FIG. 14B is a plan view of an envelope with a FIM barcode printed with a large right hand 

margin and a small logo as well as a small right hand margin and a large logo; 

FIG. 1 5 is diagram illustrating operation of a rendering algorithm to scale the logo as a 
function of the aspect ratio of a printable bounding area in accordance with an exemplary 
embodiment of the present invention; 

30 FIG. 1 6 A is a plan view of an envelope image that does not pass the margin requirements 

test; 

FIG. 16B is a plan view of the envelope image of FIG. 16A with the image rotated 180° 
to satisfy the margin requirements test in accordance with an exemplary embodiment of the 
present invention; 

35 FIGS. 1 7 A, 1 7B and 1 7C are coordinate axes used for rendering an envelope image with 

and without image rotation; 

FIG. 18 is a plan view of a page layout including a standardized axis for an envelope 
image without rotation in accordance with an exemplary embodiment of the present invention; 
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FIG 19 is a plan view of a page layout including a standardized axis for an envelope 
image with rotation in accordance with an exemplary embodiment of the presenrinvenW 

FIGS. 20A-20G demonstrate image rendering for a right feed printer in accordance with 
an exemplary embodiment of the present invention; , 4 .' " 

5 nGS.21A-21Gdemonstrate image renderingforaleftfeedprmtermaccord^^^ 

exemplary embodiment of the present invention; 

nGS.22A-22Gdemonstrateimagerenderingforacenterfeedp^ 

an exemplary embodiment of the present invention; . 
FIG. 23 is a plan view of an envelope illustrating inverted graphic components of the 
10 postal indicia as result of rotating the envelope image; . . . . 

FIG 24 is a plan view of an envelope with text components and internal data 
representation of coordinates for an image of the graphic components of the postal indicia m 
accordance with an exemplary embodiment of the present invention; _ 
FIG,25i S alogicflowdia^ 
15 an exemplary embodiment of the present invention; • . 

F1026 is a capture of an exemplary select default printer screen m accordance with an 
exemplary embodiment of the present bvention; , • anA 

FIG 27 is a capture of an exemplary print onto screen for selecting envelope size and 
other print options in accordance with an exemplary embodiment of the present invention; ^ 
20 FIG. 28 is a capture of an exemplary insert envelope screen that request a user to in ^ t - 

an envelope into the printer feeder so that a sample postage pattern may be printed print onto the 
envelope in accordance with an exemplary embodiment of the present invenuoru 

FIG 29 isacaptureofacomparesampiescreenwheremauserisrequestedtocompare 

mesampleenvelopeprintedonmeenvelopetoapostagedisplayedonanenvelopeo^ 
15 in accordance vidian exemplary embodiment of me present invent ...... 

FIG SOisacaptureofaprintqualityassuranceCQAJscreen wherein a user is requested 
to insert an envelope into the printer feeder so that a QA envelope may be printed in accordance 
with an exemplary embodiment of the present invention; _ 

FIG 31 is a capture of a mail QA envelope screen reminding the user to mail the QA 
30 envelope to the USPS in accordance with an exemplary embodiment of the present invention; 

FIG 32 is a capture of a fini^^ 
successfully completed in accordance with an exemplary embodiment of the present invenUon; 

FIG. 33 is a logic flow diagram of a print configuration wizard in accordance wtth an 

exemplarv embodiment of the present invention; 

35 FIG 34 is a capture ofa test printer screen informing the user that a sample envelope w,ll 

need to be printed to determine whether the user's printer can accurately print postage « 
accordance with an exemplary embodiment ofthe present invention; 

FIGS . 3 5-37 are diagrams illustrating a series of test patterns printed onto a test envelope 
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to determine the printer offset in accordance with an exemplary embodiment of the present 

invention; *~i 
FIG 38 is a capture of a screen asking which of a plurality of possible test patterns printed 
onto a test envelope in accordance with an exemplary embodiment of the present invention; 
5 FIG 39 is a capture of a trouble shoot screen asking which of a plurality of possible 

options a user would like to select to attempt to correct problems printing FIM barcode onto an 
envelope in accordance with an exemplary embodiment of the present invention; and . 

FIG 40isacaptureofascremirf<m^ 
FIM barcodes onto envelopes in accordance with USPS requirements in accordance with an 
10 exemplary embodiment of the present invention. 

DETAILED DESCRIPTION OF THE INVENTION 

An exemplary embodiment of the present invention enables postage systems to pnnt 
indicia-based postage within the constraints established by the USPS. An example of such a 
15 postagesystemisasoftware-b^ 

No 09/163,993 filed on September 29, 1998, by Mohan Ananda, entitled "On Line Postage 
System", the contents of which are hereby incorporated by reference as if set forth in full. The 
on-line postage system software comprises user code or client software that resides on a dient 
system and controller code that resides on a server system. The on-line postage system allows 
20 a client to securely print a postal indicium at home, at the office, or any other desired place 
An exemplary omine posuge sys^ 
toa S erversystem,whichinturnisconnectedtoaUSPS system. The server system is preferably 
capable of communicating with one or more client systems simultaneously. In operation, a 
licensed and registered client of the on-line postage system sends a request for authorization to 
25 print a desired amount of postage. A postal security device (PSD) server determines whether the 
client's account balance is sufficient to cover the requested amount of postage, and if so, 
communicates an authorization to the client system. The client system then sends image 
information for printing a postal indicium for the granted amount to a printer so that the postal 
indiciumisprintedontheprin^ 
30 printed indicium appears as a two-dimensional bar code that includes a unique serial number, 
mail delivery point information, and the amount of postage. Once the postage information is 
printed on an individual piece of mail, it may be mailed and processed by theUSPS. 

Figure 3 shows a block diagram of an exemplary Internet client/server environment used 
by the on-line postage system in one embodiment of the present invention. Personal 
35 computers(PCs) 10a-10n used by customers of the postage system may be connected to the 
Internet 12 through communication links 14a-14n. Each PC has access to a iW"*" 
printer 1 6. Optionally, a local network 1 8 may serve as the connection between some of the PCs 
such as the PC 10a and the Internet 12. Servers 20a-20m are also connected to the Internet 1 2 
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1 through respective communication links. 

Printing postal indicia requires specific information about a user's printer and its 
associated printer driver. The servers 20a-20m include information and server based printer 
databases that is accessible by the PCs lOa-lOn. The server based printer database may contain 

5 information, such as for example, model number, printer driver, print specifications (margins, 

etc). ". • 

Additionally, a client-based printer database, may be located on the user's machine. The 

client-based printer database may include a forms database that defines which media types are 

supported (e.g., envelopes, labels, postcards and the like) and the dimensions of each of these 

10 media. In an exemplary embodiment of the present invention the print engine accesses the forms 
database to locate and print the indicium, delivery address, and return address. 

Referring to FIG. 3B, when a user first tries to setup a printer with the client software, the 
server-based printer database is queried to determine if the user's printer driver information is 
contained within the database. If the printer information is in the database the required 

15 information is available and the user may continue. If the printer driver is not in the database, 
the user performs several tests to determine the required information with the guidance of a 
software, wizard. 

An exemplary on-line postage system preferably provides a print postage interface from 
which a user may define the postage that is to be printed. An exemplary print postage screen for 

20 a single recipient is shown in FIG. 4. The user may enter a return address by typing in a return 
address box 22. The user may omit the return address by activating a "Do not print the Return 
Address" option 23 . The omit return address option is preferably not active by default. 
Similarly, a delivery address box 24 preferably allows users to enter a delivery address by typing 
in the delivery address box 24 or selecting an address from an address book. If a user enters an 

25 address which is not in the address book, an exemplary system preferably allows the user to enter 
the address in the address book. The system preferably displays the address^of a single recipient 
in a format that is substantially the same as the format of the return address displayed in the 

return address window. ■ - e u 

Anexemplaryprintpostagescreenpreferablyprovidesapluralityoftogglebuttons25that 

30 allowausertoselecttherypeofmailpiecetobesent,suchasfdrexajnple,aletter,fl 

oversized box. The postage system preferably uses this information to determine what labels 

and/or envelops areavailable to ^ 

button 25 A is preferably active as the default mail piece type. A description box 26 preferably 
provides a brief description of the mail type that is currently selected by the mail type toggle 
35 buttons 25. 

An exemplary print postage screen further includes a print on drop down box 27 which 
allows users to select from envelopes and labels. The items displayed in the drop down box 27 
arc preferably determined by the type of mail piece that was selected via the mail type toggle 
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I buttons 25. For example, if a letter is selected, only envelopes and labels approved by the USPS 
may be available in the print on drop down box 27. Similarly , if a flat or box is selected, only 
labels approved by the USPS for the selected flat or box may be available. An exemplary 
embodiment of the present invention does not incorporate a default print onto media. 
5 An exemplary print postage screen allows a user to enter the weight of an item to be 

mailed into weight fields 28A. 28B. The dimensions of the weight fields may be for example 
pounds and ounces. An exemplary on-line postage system preferably allows users to integrate 
a digital scale into the postage system. The print postage screen preferably provides ah interfeces 
to a digital scale. A scale button 29 on the print postage screen preferably allows for the 
10 automatic retrieval of the weight ofthemail piece trom the scale. The system preferably displays 
this weight in the enter weight fields 28 A, 28B. A default weight is preferably 0 lbs., 1 pz. After 
the initial use, the fields preferably remember the last value. 

A select service control box 30, preferably displays apjurality of available services as well 
as the cost of each type of service for the selected mail piece type. The prices preferably update 
15 as the user inputs information into the enter weight fields 28A, 28B. If the user is typing a value, 
the display may immediately update as the user types. The price may also update as a function 
of the delivery address of a mail piece. Once a user has selected a mail service, an indication, 
such as for example, a check mark 31 may appear adjacent to the selected service. Anexemplary 
on line postage screen preferably does not select a default service type. 
20 Available postage 32 (reflecting the user's account balance) is preferably displayed on the 

print postage screen as is a print preview window 33 . The print preview window 33 is preferably 
updated in accordance with the media type selected in the "print onto" box 27. The selection of 
a print button 34 preferably advances a user to a print prompt screen as shown in FIG. 5. An 
exemplary print prompt screen allows a user to edit the properties of the selected printer and 
25 decide whether to print sample 35 or actual postage 36. In addition, envelope feed information 
37 is preferably provided for the selected printer. " 

If multiple recipients and or zone based postage rates are selected, the functionality of the 
print postage screen may change as shown in FIG. 6. When multiple recipients are selected, each 
recipient is preferably displayed as a list 38 with only the name of the individual recipients 
30 displayed. In addition, when multiple recipients from multiple zones are entered or selected, the 
price 39 of the mail piece going to the individual recipients may be displayed next to their name. 
Thisdisplay preferably appears after a weight that warrants zone based postage has been entered. 
The select a mail service dialog box 30 preferably shows a range of prices for the plurality of 
mailings. A cost of mailing dialog box 40 preferably appears when multiple recipients are 
35 selected. The cost of mailing dialog box 40 preferably displays the total cost for the mailing. 

Selection of an options button 4 1 on the print postage screen preferably advances the user 
to an options dialog box, that corresponds to the media type selected in the print onto box 27. 
For example, if an envelope is selected in the print onto box, an envelope options screen as 
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1 shown in FIG. 7 may be launched. An exemplary envelope options screen includes a control 42 
to disable FIM barcode printing. This control preferably includes a graphic representation 43 of 
a FIM barcode to visually define the term FIM barcode. In addition, the envelope options screen 
preferably includes the ability to postdate a mail piece 44 by allowing a user to enter a date in a 
5 text edit box 45. 

An exemplary envelope options screen further includes a plurality of indicium correction 
options 46, such as for example, printing corrected postage 48 or a corrected date 50. A return 
address graphic control 52 preferably allows the user to select a graphic to be printed with the 
return address. Return address adjustment controls 52 provide me ability to adjust a plurality of 
10 features including, for example, the font to be used in the return address and the margins. 
Delivery address adjustment controls 54 may also be included. 

An exemplary envelope options screen also includes an indicium graphic control 56. The 
on-line postage service provider preferably controls the graphic tiiat can be displayed witlun the 
indicium. Therefore, the online postage system preferably provides graphics for the indicium in 
15 a digitally signed format, embedded within a DLL. The system may also provide clip art that a 
user may browse to select the indicium graphics. The onrline system may provide for 
independent downloading of the DLL, so that a clip art library can be updated without forcing 
a complete download of the entire client software; If the DLL is not present, this control is 
preferably unavailable. 

20 The USPS regulations indicate that users may not incorporate a logo into the indicium 

without prior approval by the USPS. The USPS regulations greatly restrict a user's ability to 
customize the indicium. Therefore, an exemplary on-line postage service provides means by 
which users can customize their mail piece with a graphic file of their choosing. The envelope 
options screen preferably provides a return address logo control 76 which allows the user to 
25 incorporate a graphic 78 into the return address area (see FIG. 8). In an exemplary envelope 
options screen a logo is not incorporated into the return address area by default. A browse button 
80 is preferably provided to allow a user to open a standard dialog box, from which a user may 
browse for and select a return address graphic. A preview window 82 provides a preview of the 
selected return address graphic: FIG. 8 illustrates the inclusion of a graphic 78 in the return 
30 address area of an envelope. 

Referring to FIG. 9, the present invention utilizes a combination of processes to print 
postal indicia onto envelopes in accordance with the regulations set forth by the USPS. In an 
exemplary embodiment of the present invention, the process of printing postal indicia begins with 
the characterization of a default printer through the collection of set-up information regarding that 
35 printer's performance characteristics and default settings 77; Set-up information may include for 
example, how the printer rotates into landscape mode, what print media/paper the printer 
supports, what feed tray options the printer supports or other default information. 

In an exemplary embodiment of the present invention, the client software may gather set- 
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up information through database queries or manually with the use of a printer configuration 
softwarewizard. An exemplary embodiment of the present invention creates a dynamic database 
that alleviates the need to require all users to provide specific information about their printer: 
The dynamic printer database may be updated for the entire user community whenever a user 
manually sets-up a new printer. In one embodiment, the dynamic database may be maintained 
on the server of the postal provider. The dynamic database may contain information, such as for 
example, model number, printer driver, print specifications (margins, etc) and which media the 
printer is allowed to support as well which media the printer is not allowed to support. This 
allows the postal provider to remotely control the type of media and printers that are or are not 
available for use. 

The server-based printer database may use a plurality of tables in a user support database 
tostoreirdbrmationaboutprimerdrivers. For example, a printer corfiguration information table 
may be used to store information on known printer drivers (printer drivers that have been tested 
successfully, either in house or by a consensus of users' results) and the print media they support 
Similarly a printer global configuration table may be used to store settings that affect all printer 
drivers, both known and unknown, and a printer database update table may be used to store the 
results generated when a customer configures a previously unknown printer. 

In addition to these tables, information that is specific to a customer's printers (i.e. driver 
version numbers, whether or not a printer has been configured, etc.) may be stored in the 
Registry Each time a user logs into the postal service using the client software, a plurality of 
information is preferably sent to the postal service provider over the Internet. For example, the 
most recent date when the printer information in the Registry was updated with the printer 
information from the server based printer database may be sent. In addition, the names of printer 
drivers and printer driver version numbers that are installed on the user's computer are also 
preferably sent to the postal service provider. 

Thelatestupoateorserverdaterepresentstoedatewhen 
was last updated. If the date in the Registry is more recent than this server date, then the server 
does hot update the printer information in the client based printer database. If the date in the 
Registry is earlier or the same as the server date, then updated printer information from the 
server-based printer database may be returned to the client based printer database. The client 
software then preferably updates the printer information in the Registry and updates the date 
information with the current system date : 

The latest update value is preferably updated each time the Registry information is 
compared with the server information. The print engine preferably uses the information in the 
Registry along with the aforementioned tables in the client support database to determine which 
printer drivers are available for use as well as the print media that may be supported by each of 
the available printers. If a user works offline, the client software may use Registry values without 
being connected to the support server to access the server-based printer database. 
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1 The printer configuration information table is the main table in the print server database. 

It contains information on printer drivers, such as for example, the version number, compatible 
operatmgsystems,andmeprmtme(uamedriverssupport. The prmter configuration uiformation 
tablemayalsostoremelowestversionofmeprimerdrivermatmeetsallm^ 
5 The printer engine compares the driver version number of a user's printer with the driver 
versions) listed in the database. The printer engine preferably breaks up the string based on 
punctuation and then compares the numerical groups. If letters are included in the driver version, 
the engine does a character by character comparison. 

The printer configuration information table may also store an offset or shift code for the 
10 default paper feed tray supported by this driver. The shift code represents how the guides of the 
paper feed trays are moved to properly feed envelopes into the printer. The shift code tells the 
printer engine where to place the image on the larger virtualized sheet of paper. If the printer 
does ;not shift the image at all, this value is preferably set to zero. If the printer shifts the image 
to the middle of the page, this value is preferably set to one. If the printer shifts the image across 
1 5 the page, this value is preferably set to two. A print test may be run to determine the proper shift 

code. .. . . v • 

The printer configuration information table stores a variable indicating whether a given 

prmtdriversuppomvirtualizationandprintmgonenvelopesa^ 

such as, for example, post cards or labels. If a user attempts to print to a print media not 
20 supported by the selected printer, the system preferably informs the user that their pnnter does 
not support the selected print media and allows the user to select a new printer or select a new 

print media. . 

The prim media fields in we printer conf*^ 
cases where the majority of printer drivers support a print media. For example, while the 
25 majority of printer drivers support personal envelopes, some do not. In these instances, the 
personal envelope may still be an option in the "print oh" list in the print postage screen. The 
system preferably notifies user's who attempt to print to a print media that is not supported by 
their printer driver, that the selected printer does not support that print media. 

The primer configuration information table may also contain a horizontal page offset 
30 variable which is utilized when an image is shifted to the right or left on a label by a minority of 
printers but is otherwise properly printed onto the label by a majority of printers. If this occurs, 
the image may be translated by the horizontal page offset -variable which represents the distance 
that the image should be shifted to properly print on the label. Negative values may be used to 
move the image to the :left and positive values may be used to move the image to the right. 
35 Similarl>^averticalpageoffsetvaluemaybestoredtocompensateforp^ntersthatrequlre 

the user to move one of the paper feed guides a fixed distance and then to move the other paper 
feed guide as needed to fit an envelope. This may result in the default shift code being reported 
as a one when it's really a zero or as a two plus the distance that you are required to move the 
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fixed paper guide. When envelopes are printed, the information may be shifted up or down (the 
same distance as the fixed-distance paper feed guide) and printed incorrectly on the enve op* 
To compensate for this problem, the system preferably stores the distant the image should be 
shifted in order to print correctly. Printing on the envelope may be raised, for example, by 
5 storing a negative value and lowered by storing a positive value. 

A landscape orientation variable may compensate for printer drivers that over rotate the 
image which would otherwise result in the image being shifted horizontally across the page, 

The printer global configuration table may be used to control printer driver settings. The 
setting of a global variable allows unknown printers and determmesifprinterdriversthatarenot 
10 in the database will be supported. If unknown printers are not allowed, the system preferably 
does not allow a user to configure an unknown printer in a getting started wizard. Ramer the 
system preferably notifies the user that the selected printer is not supported. 

Similarly thesystem will not allow a user to select an u^ 
screen In addition, the setting of a global FIM specification mode variable, determmes the 
15 distance from the top of an envelope a FIM may be printed when virtualizaticaMS not used. 
DMM regulations require that the FIM be no lower than 0.125" from the top of the envelope. 
This field may be set to allowthe FIM to print in accordance with the DMM regulations unless 
the regulations regarding FIM placement change. 

When a client configures a printer, the results of the configuration may be saved in the 
20 printer database update table. As a result, thistable contains information about both knownand 
unknown printer drivers so that there is overlap between the fields of this table and me fields m 
theprinterconfigurationinformationtable. The information in the overlapping fields for a new 
printer driver may be transferred to the printer configuration information table after numerous 
customers, on the order of five to twenty, have successfully configured thepnnterdnverwtththe 
25 same operating system, version number, and shift code. ^ 

The svstem preferably stores a user identification to identify the useMhat configured the 
printer driver in this record. This identification is preferably a unique number assigned to a user 
when they reeistered with the on-line postal provider. The printer database update table may 
store*etext;ameofthe^ 
30 operating system used when the printer driver was configured and the date the dnver was 

COnf Tdditionally, a client-based printer database, preferably located on the client's machine 
may include a forms database. The forms database defines which media types are supported 
(such as, for example, envelopes, labels, postcards and the like) and the dimensions of each of 
35 these media so that me printing engine knows where and how to print me indict 

The forms database preferably stores one record, with a unique identtfcauon, for every 
print media that the svstem supports. The database preferably identifies the print media as bemg 
either an envelope or a non-envelope type. The type value tells the print engme Which fields U 
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needs to lookat in the record, ^eserecordscoaespondto 

print postage dialog screen in the client software. _ 

An exemplary embodiment of the present invention prints on envelopes in accordance 
• vvitHbywayofexample.meDMMregulatior^^ 

of the return address, etc:). However, for labels, the system preferably prints in accordance with 
the label-specific fields in the forms database, for example the fields that define the locahoafor 
the indicium, return address, and the delivery adciresses. Tlie forn^ database allows each me^ 
type stored in the database to be individually enabled or disabled. The system may enable a 
media type when the media type is first created. _ . 

A paper height variable may be used to identify the size of the pnnt media. The paper 
height variable includes the height of the media in standard units such as for example m* 
(1/lOOOth of an inch increments). Paper height is measured based on the enure lengthofthe 
rnediafromtoptobbttom. The paper height v^ 

on label sheets or other print media. . 
i Similarly a paper width variable may be used .p identify the width of the prmt medta. 

Again, an exemplary paper width variable includes the entire width of the media from left to 

syLn to interpret the size of the print media. This field ma, be for example the standard 
Windows® code for a paper size. \ 

prin^gn.upswhich^updriversnta.supportanKdiagroup. The group drivers may conUun 
^r^esofmeprin^driventosupportspedfieprmtmedi, A variable may be included 
for each driver in a group documenting whetfier the printer driver supports 
!5 AnexempiaryembcKumentofthep^^ 

«, perform a margin requirements test to define wheurer the printer in use can p™, poaal 
indicia in accordance with USPS regulations 79. If default envelope margin size for me 

postage. Tl-cli«»^d«^fc«^tol3.1^-«-«»-*- 

Lge„fanenvelopeon M avirrua,izedshee, 

suppoits a plurality of virmal sheet sizes including for example 8 K x 11 B5 (182mm x 
IsTmm), or 1 1" x ir. The size of the vinualized sheet may be determined by me size of the 

35 10 ; „ exemp , aiy vinualizauon processes ensures that uieenvelope 

imagers copied within a "envelope image area" 90 of the vinualized sheet 92 f Thus, even 
thoughthe user insens an envelope 94 into the printer, the exemplary software preferably sends 
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print commands to the printer for a virtualized sheet 92. 

Referring to FIG. 11, the printable region (me ana within the dashed lines) of a virtualized 
sheet 92 may be determined by four margins, namely the top margin 89, bottom margin 91, left 
margin 93 and the right margin 95. In addition, an exemplary system defines an origin point 97 
for the virtualized sheet 92. The origin point 97 is preferably used to calculate the locationofthe 
image within the printable region. In portrait mode the edge of the paper that feeds into the 
printer first is known as the leading edge 91. In portrait mode the system preferably places the 
origin point 97 at the left corner of the leading edge of the virtual sheet If the print job is rotated 
into landscape mode, the system moves the origin to the opposite edge of the sheet, known as the 
trailing edge. 

Printer virtualization preferably orients the FIM barcode near the middle of the virtualized 
sheet thereby alleviating any physical margin constraints that might otherwise prevent a printer 
from printing the FIM barcode within 0.125" from the top of the envelope. In fact, the use of 
print commands for a virtualized sheet may allow the FIM barcode to be printed up to the edge 
of the envelope. 

Printer offset or shift code is a variable dependent upon how an envelope is fed into a 
printer. Referring back to FIG. 9, the client software uses the printer offset to locate the envelope 
image with in the printable region of the virtualized sheet 85. Envelopes are fed into printers by 
means of feed trays. Feed trays typically have guides that align the print media to prevent it from 
skewing. However, the location of the feed tray and the way in which the envelopes are loaded 
may vary from printer to printer. Therefore, the printer offset variable may also vary from printer 
to printer. 

For example, referring to FIG. 12 the paper guides may load the envelope from the left, 
right, or center of the feed tray. In addition, the feed trays can be physically located in various 
places on the printer, for example on the top, front, back, or sides of the printer. The different 
locations of the feed trays make it difficult to classify printers (that don't feed from the center) 
as left or right. Therefore, an exemplary embodiment of the present invention classifies printer 
offset in terms of top and bottom offsets rather than left and right. 

In an exemplary embodiment of the present invention the origin or reference point for the 
virtualized sheet is used to calculate the location of the envelope image. Referring to FIG. 13, 
printer offset may then be defined in terms of the vertical relationship between the envelope 
image and the origin of the virtualized sheet. If the set-up information on the print driver of the 
user's printer was not in the dynamic printer database, an exemplary embodiment of the present 
invention utilizes a wizard program to initially determine printer offset. The wizard program 
preferably generates one or more test shapes that are printed on a test envelope by the user's 
printer. Printer offset may then be defined by determining which of these shapes actually gets 
printed onto an envelope, (i.e:, whether it is a top 108, bottom 104, or center 106 offset), 

Once an offset is determined for a given printer the offset is preferably stored in the 
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1 dynamic printer database so that future users who have the same printer may not have to exercise 
the wizard program to determine the printer offset. Rather/future users preferably obtain the 
offset information from the dynamic printer database. Once the system determines the offset, the 
envelope image may be located within the printable region of the virtualized sheet 
5 Portrait mode is the default orientation of a normal printjob. However, since envelopes 

are typically printed in landscape mode the system software preferably modifies the printer 
setting from "portrait" to "landscape"? mode. Printers handle the landscape mode in different 
manners. Some printers rotate the portrait image 90 ° to create a landscape image while others 
rotate the portrait image by 270°. Therefore, the ultimate location and orientation of the 
10 envelope image within the printable region of the virtualized sheet depends on the rotation 
undertaken by the printer to achieve landscape mode. 

Referring back to FIG. 9, when the envelope image is properly located in the printable 
region of the virtualized sheet in accordance with the printer offset, the client software again 
performs a margins requirements test to determine whether the printer in use can print postal 
15 indicia in accordance with USPS regulations 86. If the margins for the virtualized sheet satisfy 
the margin requirements the client software uses rendering algorithms 87 to relocate the origin 
of the virtualized sheet to print the postal indicia onto the envelope 81. 

As part of the rendering process, an exemplary embodiment of the present invention may 
incorporate a logo of the postal service provider in the postal indicia. Rather than integrating a 
20 single, static logo, the print engine preferably accommodates a scalable logo 84. In order to 
conform to the FIM placement standards which require that the FIM consistently be printed 2" 
+/- 1/8" from the right-hand edge of the envelope, the space available between the FIM and the 
human-readable portion of the indicium changes depending upon the right-had margin of the 
printer. 

25 Referring to FIG. 1 4A the area between the right edge of the FIM barcode and the right 

hand edge of the envelope can be divided into a plurality of distinct sections, described as 
follows: 

v "A" is the distance from the edge of the indicium to the edge of the paper. In many 
cases, this distance is determined by the physical margin of the printer, and is 
30 therefore a variable amount. 

"B" is the width of the human readable portion of the indicium. This width is 
preferably fixed. ' 

• "C" is the width of a logo graphic. This width may be variable. 

• ' "D" is the width of a FIM clear zone; Its width should also be fixed. 

35 To satisfy the requirements promulgated by the USPS the distinct sections involved in 

locating ihe FIM barcode from the right hand edge of the envelope may be constrained as 
follows: 

1.875" <A + B + C + D < 2.125" (1) 
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Since B, the width of the human readable portion, and D the width of a FIM clear zone are 
preferably fixed, the system preferably reduces the size of C (the logo)when A (the printer 
margin) increases, to satisfy the above equation. Similarly, when A (the printer margin) 
decreases, the system preferably increases the size of C (the logo) so as to increase the branding 
within the indicium. : A right hand margin (A) of about 7/10" or less allows the client software 
to print a logo (C) in the postal indicium. Generally/for a particular printer, the logo size will 
be constant for all envelope jobs. 

An exemplary embodiment of the present invention shifts the human readable portion in 
accordance with the printer margin and scales the logo in a manner mat maximizes the size of 
the logo while preserving the validity of the equation above. Referring to FIG. 14B, when a large 
printer margin 96 is required, a small logo 98 is preferably printed. Similarly, when a small 
margin 1 00 is allowed, the human readable portion shifts towards the edge of the envelope and 
a larger logo 102 is preferably printed, the latter is generally preferable since it provides more 
prominent branding and is considered more aesthetically appealing to the user. 

Referring to FIG. 15, an exemplary rendering algorithm for scaling the logo while 
maintaining the validity of Equation (1) above defines a printable bounding area 103 or a 
bounding rectangle and scales the logo to fit into the printable bounding area. Referring back to 
FIG. 14, the width of the printable bounding area is the distance between the human readable 
portion and FIM clear zone. The height of the printable bounding area is equal to the distance 
between the two dimensional bar code and the edge of the print media. 

Referring back to FIG. 15, in operation the described exemplary rendering algorithm 
determines the aspect ratio (defined as the width/height) of the bounding area as well as the 
aspect ratio of an image area 107 that bounds the logo. If the aspect ratio of the bounding area 
is greater than the aspect ratio of the image area the rendering algorithm may scale the image to 
fill the printable bounding area. The rendering algorithm may create a vertical scale factor, 
defined as the height of the bounding area divided by the height of the imagearea, and scale the 
image vertically by multiplying the image height by the vertical scale factor. Further the 
rendering algorithm may create a horizontal scale, factor defined as the width of the bounding 
area divided by the width of the image area, and scale the image horizontally by multiplying the 
width of the image area by the horizontal scale factor. 

An exemplary rendering al gorithm for scaling the logo may best be demonstrated with an 
example. Therefore for purposes of illustration only, assume a printable bounding area has a 
width equal to eight and a height equal to four and therefore an aspect ratio of two. Further 
assume an image area has a width of three and height of three and therefore an aspect ratio of 
one. In this instance the vertical and horizontal scale factors are equal to 4/3 so that the image 
area may be scaled horizontally, vertically or both with a scale factor of 4/3. 

Referring back to FIG. 9, if the margins for the virtualized sheet do not satisfy the margin 
requirements an" exemplary embodiment of the client software rotates the envelope image one 
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[ hundred and eighty degrees 88. In these cases,ihe client soft^ preferably queries the server 
based printer database to determine if the user's printer and print drivers are capable of errorfree 
rotation. The system preferably limits rotation to cases where the server based printer database 
certifies that the printer and print drivers support rotation without error. 
5 Referring to FIG. 16A, in operation the client software preferably checks the margin 

requirements (top margin less than or equal to 0.125" and right margin less than or equal to 
0.70") to determine whether the image will properly print onto the envelope in accordance with 
USPS requirements . Referring to FIG. 16B, if the margins of me virtualized sheet do not satisfy 
the margin requirements the client software rotates the envelope image. 
10 Referring back to FIG. 9 the client software tests the margin requirements again 86 after 

rotation. If the margins of the virtualized sheet, with the rotated image, fail to satisfy the margin 
requirements, the client software cannot print the envelope 89. If the margins of the virtualized 
sheetsatisfy the margin requirements wim rotation the client software renders me envelop i^ 
87 and prints the envelope 81. Thus, the rotation process can help determine the ultimate 
15 orientation of the envelope image on the virtual sheet of paper. 

To print postal indicia, the client software preferably uses a drawing surface to render an 
envelope image contained in a printable region of a virtualized sheet. The drawing surface may 
be used to calculate the location of each character to be printed. The drawing surface is 
preferably represented by a coordinate system having a logical origin. Each point on the ; 
20 coordinate space is represented by a set of coordinates, X and Y, (x,y). The (x,y) coordinates 
determine the precise location of the object to be drawn. Microsoft Windows supports four 
different coordinate spaces. 

The attributes of a particular coordinate system are defined by the mapping mode. Page- 
space coordinates set me mapping mode. The mapping mode defines me unit of measure 

25 to translate the page-space coordinates into the device-space coordinates used by a printer, and 
also defines the orientation of the device's x and y axes. For example, in HiEnglish mapping 
mode, each unit in the page-space coordinates is mapped to 0.001" in device-space coordinates 
and the value of X increases to the right and Y increases up from the bottom. 

To support printing to a particular printing device, the client software preferably maps or 
30 copies the page area from one coordinate space to another. The client software initially renders 
the objects on a coordinate space called page space (sometimes referred to as logical space) using 
a modified Hi English mapping mode and translates the objects to the device coordinate space. 

Referring to FIG. 17A, an exemplary embodiment of the present invention utilizes a 
standard x and y coordinate system. To standardize the coordinate area, an exemplary 
35 embodiment of the present invention preferably flips the x axis and y axis to support rotations 
that are necessary to print the image. The client software uses Windows mapping code that 
allows the axes to be flipped and creates a custom mapping code. 

FIG. 1 7B shows the axes used by the client software for envelopes without rotation. The 
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L action of flipping fonns a standard coordinate space with the positive x axis pointing to the right 
and the positive y axis pointing down. Similarly, FIG. 17C shows the custom axes used by the 
client software for envelopes with rotation. 

Referring to FIG. 1 8, the origin 1 09 of the virtualized sheet is preferably located at the top 
5 left-hand corner of the printable region of the virtualized sheet (the envelope.) The x and y 
coordinates may then be calculated from the origin. For example, if the positive X axis points 
to the right and the value of X is five, an exemplary drawing routine translates to the right side 
of the origin five units. Alternatively, if the positive X axis points to the left side and the value 
of X is five, the system drawing routine translates to the left side of the origin five units. 
10 Referring to FIG. 1 9, when the envelope image is rotated, the client software flips the X-axis so 
the positive X-axis points to the left direction and the positive Y-axis points upward. 

If the origin is not at the top-left corner of the envelope, the client software translates the 
origin of the virtual sheet to the top-left comer of the envelope. For top, center or bottom offset 
printers the origin of the virtualized sheet preferably translates in the positive X direction a 
15 distance equal to the value of the paper-width minus envelope-width. Similarly, for center offset 
printers the origin preferably shifts in the positive y direction a distance equal to the value of (the 
paper-height minus envelope-height) divided by two. For bottom offset printers the origin 
preferably shifts in the positive y direction a distance equal to the value of the paper-height minus 
envelope-height 

20 In addition, the server based printer database may contain shift overrides. An exemplary 

embodiment of the present system preferably queries the server based printer database to 
determine if shift overrides exist and if so applies those overrides. An exemplary system further 
determines whether the image should be rotated. If so the software preferably translates the 
origin diagonally across the envelope image. To shift the image, the x axis translates in the 
25 positive X direction a distance equal to the value of the (envelope-width minus the left margin 
width) minus the width of the right margin. In addition, the y axis translates in the positive y 
direction a distance equal to envelope height minus the height of the top margin. The rendering 
process translates the logical coordinates of the image to device coordinates of the printer to 
correctly locate and print the indicia on the mailpiece. 
30 The operation of an exemplary image printing process may be best demonstrated with a 

series of examples. FIG. 20 A shows a right hand feed printer with a printable location in the 
portrait mode. As shown in FIG. 20B when the printer rotates 270° into landscape mode the 
origin 109 of the virtualized sheet is at the leading edge 110 of the virtualized sheet. An 
exemplary embodiment of the present invention performs a margin requirements test to 
35 determine if the printer top margin 1 11 (relative to the origin of the virtual sheet) is less than 
0.125" (to support FIM printing to USPS requirements) and the right margin 1 12 is less than 
0.70" (to allow a logo of the postal service provider to be included in the indicium). If the image 
satisfies the margin requirements the postal indicia prints correctly onto the envelope as shown 
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1 in FIG. 18D. 

However, referring to FIG. 20C, if the image does not meet the margin requirements, the 
client software rotates the image 180°, and tests the margins again. To perform the margin 
requirements test with a rotated the image, the ^ client sot^are substimtes the bottom margin for 
5 the top margin and the left margin for the right margin. Thus me bottom rnargin should now be 
less than 0.125" and the left margin should now be less than ^^OJOMfthe rotated image satisfies 
the margin requirements the client software may use rendering algorithms to relocate the origin 

and print the image correctly. 

Referring to FIG. 20E when a right hand feed printer rotates 90° into landscape mode the 
10 origin 109 of the virtualized sheet is not located at the leading edge 110 of the virtualized sheet. 
An exemplary embodiment of the present invention performs a margin requirements test to 
determine if the envelope image satisfies the predetermined margin requirements, (i.e. printer top 
niargmislessm^ 

requirements test the postal indicia prints correctly onto the envelope as shown in FIG. 20G. 
15 However, referring to FIG. 20F, if the envelope does not meet the margin requirements 

test the postal indicia, including FIM barcode may be located outside the printable region of the 
virtualized sheet and the envelope may fail the USPS requirements for FIM barcode placement 
The client software therefore, rotates the image 1 80°, and performs me inargin requirements test 
againlfmeimagesatisfiesmemargmre^ 
20 to print the postal indicia onto the envelope. In this instance the origin is preferably shifted 
across and down the page so that the image may be correctly printed. 

Similarly, FIG. 21 A shows a left hand feed printer with a printable location in the portrait 
mode. As shown in FIG. 21B when the printer rotates 270° into landscape mode the origin 109 
ofthevirtualizedsheetislocatedattheleadingedge 1 10 ofthe virtualized sheet, Anexemplary 
25 embodiment of the present invention performs a margin requirements test to determine if the 
envelope image satisfies the predetermined margin requirements, (i.e. printer top margin is less 
than 0.125" and the right margin is less than 0.70"). If the image satisfies the margin 
requirements the postal indicia prints correctly onto the envelope without image rotation as 
shown in FIG. 21D. The client software may therefore use rendering algorithms to relocate the 
30 origin and print the envelope. ^ 
However, referring to FIG. 21C, if the image does not meet the margin requirements, the 
client software rotates the image 1 80°, and performs the margin requirements test again. If the 
image satisfies the margin requirements, the client software may use rendering algorithms to 
relocate the origin and print the image correctly. 
35 Referring to FIG. 21 E when a left hand feed printer rotates 90° into landscape mode the 

origin 109 ofthe virtualized sheet is not located at the leading edge 1 10 of the virtualized sheet. 
An exemplarv embodiment of the present invention performs a margin requirements test to 
determine if the envelope image satisfiesthe predetermined margin requirements, (i.e. primer top 
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I rr*rgmislessman0.125"andm^^ 

requirements test the postal indicia prints correctly onto the envelope without rotation as shown 
in FIG. 21G. The client software uses rendering algorithms to shift the origin and print the postal 

indicia onto the envelope. 
5 However, referring to FIG. 21F, if the envelope image does not meet the margin 

requirements, the postal indicia, including FIM barcode may be located outside the printable 
. region of the virtualized sheet and the envelope may fail the USPS requirements for FIM barcode 
placement. The client software therefore, rotates the image 180°, and performs the margin 
requirements test again. If the image satisfies the margin reqmrements me client software uses 
10 rendering algorithms to print the postal indicia onto the envelope. In this instance the origin is 
preferably shifted across and down the page so that the image may be correctly printed. 

As a further example, FIG. 22A shows a center feed printer with a printable location in 
the portrait mode. Referring to FIG. 22B, when the printer rotates 270° into landscape mode the 
origin 109 of the virtualized sheet is at the leading edge 110 of the virtualized sheet An 
15 exemplary embodiment of the present invention performs a margin requirements test to 
detemine if me envelop image satisfy 

margin is less than 0.1 25" and the right margin is less than 0.70"). Ifme image passes me rnargin 
requirements test the postal indicia prints correctly onto the envelope without image rotation as 
shown in FIG. 22D. The client software may therefore use rendering algorithms to relocate the 
20 origin and print the envelope. 

However, referring to FIG. 22C, if the image does not meet the margin requirements, the 
client software rotates the image 180°, and performs the margin requirements testagain. If the 
image satisfies the margin requirements, the client software may use rendering algorithms to 
relocate the origin and print the image correctly, 
25 Referring to FIG. 22E when a center fed printer rotates 90° into landscape mode the origin 

109 ofthe virtualized sheet is not located at the leading edge 110 of the virtualized sheet. An 
exemplary embodiment of the present invention performs a margin requirements test to 
determine if the envelope image satisfies the predetermined margin requirements, (i.e. printer top 
margin is less than 0. 1 25" and the right margin is less than 0.70"). If the image passes the margin 
30 requirements test the postal indicia prints correctly onto the envelope without rotation as shown 
in FIG. 22G. The client software uses rendering algorithms to shift the origin down and across 
and print the postal indicia onto the envelope. , 

However, referring to FIG. 22F, if the envelope does not meet the margin requirements, 
the postal indicia, including FIM barcode may be located outside the printable region ofthe 
35 virtualized sheet and the envelope may fail the USPS requirements for FIM barcode placement. 
The client software therefore, rotates the image 1 80°, and performs the margin requirements test, 
again. If the image satisfies the margin requirements the client software uses rendenng 
algorithms to print the postal indicia onto the envelope. In this instance the origin is preferably 
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shifted across and down the page so that the image may be correctly printed. Thus, the rotation 
process can help determine the ultimate orientation of the envelope image on the virtual sheet of 
paper. 

In the described exemplary embodiment the client software flips the X-axis so the positive 
X-axis points to the left when the envelope image is rotated. Certain printers may hot be able to 
support flipping the X-axis. As a result, these printers may print the postal indicia with the 
graphic portion inverted or without the graphic altogether (see FIG. 23). Therefore, an exemplary 
embodiment of the client software preferably includes a two pass graphic rendering routine that 
allows the client software to separately render the textual and graphic; components of the 
mailpiece. 

In operation, the client software performs a first set of adjustments to the drawing surface 
and renders the textual components, including the delivery address 1 14, the return address 1 15 
and the indicium 116 of the mailpiece. The client software preferably stores the image 
information for the graphic components as well as the comer coordinate points of the location 
where the image of the graphic components are to be printed (see FIG. 24). 

The graphic components include the 2-d Bar code 1 1 7, the return address graphic 1 1 8, the 
indicium graphic 119 and the service provider logo 120. Once the textual information is 
rendered, the client software preferably adjusts the drawing surface a second time. In the 
described exemplary embodiment, the client software resets the mapping mode to MM_TEXT, 
each logical pixel maps to a physical device pixel, the positive X axis points to the right, and the 
positive Y axis points downward. The client software traverses the list of saved images of the 
graphic components, rendering them for printing using the new coordinates. 

However, the axes have been flipped in the opposite direction from the standard rotated 
mode. Therefore, the client software preferably rotates the images of the graphic components 
1 80°. In an exemplary embodiment of the client software, the images of the graphic components 
are rotated in memory using standard image processing techniques. Upon completion of printing 
the client software refreshes the drawing surface to its original state before any adjustments were 
made. 

An exemplary embodiment of the present invention includes various print setup wizards, 
such as for example, print verification, print QA envelope and determine top, center or bottom 
envelope feed. The print setup wizards are preferably stored in a printer setup portion of a getting 
started wizard that a user may execute before utilizing the software. 

An exemplary logical flow diagram of the printer setup component is shown in FIG. 25. 
An initial default printer selection screen 121 allows the user to select a default printer. A prim 
onto screen 1 22 then prompts the user to select an envelope size to be used for printer setup 
testing. Next the system may determine 124 whether the default printer selected by the user is 
stored in the server based printer database. I f the default printer is riot included in the database 
the system defaults to a printer trouble shoot wizard 126 to determine the feed offset for the 
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selected default printer. 

If the default printer is included in the database an insert envelope screen 128 preferably 
prompts the user to insert an envelope into the printer to complete further setup testing. The 
system then prints a test sample 130 onto the envelope inserted into the printer. A compare 
sample screen 1 32 preferably then prompts the user to compare 1 34 the printed postage sample 
with a representative envelope displayed on the screen. If the postage sample printed on the 
envelope does not match the postage on the displayed envelope the system may again default to 
a printer trouble shoot wizard 136 to determine the feed offset for the selected default printer. If 
the printed sample matches the displayed postage the system may upload 138 print parameters 
for the selected default printer into the server based print database. 

The USPS requires users of computer-based postage processing systems to mail in an 
actual postage sample printed on what is known as a quality assurance (QA) envelope. The 
USPS utilizes the QA envelope to confirm that the printed postage complies with the 
promulgated USPS standards. Since the QA envelope must include valid postage the system 
preferably determines whether the user's account balance 140 is sufficient to cover the postage. 
If the account balance is sufficient a print QA envelope screen 142 may inform the user as to the 
requirements for a QA envelope and prompts the user to insert an envelope into the printer. The 
system may then print 144 a valid postal indicum onto the inserted envelope. A mail QA 
envelope screen 146 may then prompt the user to forward the QA envelope to the USPS. A 
finish screen 147 may then inform the user that the set-iip wizard has been , successfully 
completed. 

FIG. 26 shows an exemplary select default printer screen 121. The select default printer 
screen 1 21 may inform the user that sample patterns need to be printed to verify compliance with 
USPS requirements. A drop down box 1 55 may display the printers that are installed on the 
user's system, and allow the user to select a default printer. The default printer selection is 
preferably incorporated into the standard print prepare dialog box, and therefore remains the 
default printer until the user selects otherwise. In the described exemplary embodiment, a 
"Next>" button 1 56 is not available until the user selects a default printer, 

Referring to FIG. 27, an exemplary print onto screen 122 may allow the user to select 
information needed to support the print test functions. For example, a drop down box 1 57, may 
be used to allow users to select the size of the envelope to be used throughout the tests. The user 
may also be allowed to omit the return address. For example, the user may be allowed to select 
a "yes" button 1 58 with the mouse to print the return address or a "no," button 1 59 to prevent the 
return address from printing. 

The user's selections may be stored and used for all testing undertaken within the print 
setup wizard. The information that is gathered here may also be used to populate the 
corresponding fields within the print postage and print options dialog boxes when the user first 
launches these screens. In an exemplary embodiment of the present invention, a "Next>" button 
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1 60 is not available until the user selects an envelope size and answers the yes/ho question. 

Referring to FIG. 28, an exemplary insert envelope screen 128 notifies the user that 
postage is about to be printed, and instructs the user to load an envelope into the feeder. A 
graphic 162 of ah envelope being placed into a printer is preferably used to help re-enforce the 
action to the user. This screen may be used multiple times during the printer setup portion of the 
getting started wizard. A "Next>" button 1 64 may be immediately available. When the ,< Next>" 
button is selected, a sample Quality Assurance (QA) envelope is preferably printed. 

Referring to FIG. 29, an exemplary compare sample screen 132 prompts the user to 
compare the QA envelope with the envelope 166 displayed on the screen. The QA envelope 
preferably contains, FIM barcode, a human readable portion 1 67 and a two dimensional barcode 
portion 1 69. The human readable portion 1 67 niay contain the postage value, mail class, the date 
and the meter number. In addition, a logo 1 7 1 and the destination zip code may be included. The 
two dimensional barcode 1 69 is intended to help thwart fraud, and may include information about 
the mail piece, such as for example^ the destination ZIP code, the amount of postage applied, the 
date and time the postage was applied, and a digital signature so that the USPS can validate the 
authenticity of the postage. The user preferably verifies that each of the postal indicia features 
printed on the QA envelope match those displayed on the compare sample screen 132. In an 
exemplary embodiment of the present invention, neither a -yes" radio button 1 68 or a "no" radio 
button 1 70 is selected by default. A "Next>" button 1 72 is preferably not available until the user 
selects either the yes or no button. 

Referring to FIG. 30, an exemplary print QA screen 142 is similar to the insert envelope 
screen. The print QA screen 142 may educate 174 the user about the purpose of and 
requirements for QA envelopes. In addition the print QA screen 142 may instruct the user to 
load an envelope into the feeder because postage is about to be printed. A graphic 176 of an 
envelope being placed into a printer may be used to help re-enforce the action to the user. 
Further, the user may also be informed that the USPS requires QA envelopes to include valid 
postage and that the user' s account will be debited for this postage. A "Next>" button 1 78 may 
be immediately available. When the "Next>" button 1 78 is selected, a QA envelope is printed. 

Referring to FIG. 3 1 , an exemplary mail QA envelope screen 146 preferably instructs the 
user to promptly mail the QA envelope or the user's meter license may be revoked. A graphic 
180 of an envelope being placed into a mail box may be used to help re-enforce the action to the 
user. A ''Next>'' button 182 may be immediately available. 

Referring to FIG. 32 an exemplary finish screen 147 may be used to congratulate the user 
for completing the set-up wizard, and to launch online postal service software. A "Finish" 
button may be available immediately. Once the "Finish" button has been selected, the client 
software is preferably launched. 

A print configuration wizard may be initiated if print parameters for the default printer are 
not stored in the server based printer database, or if the sample QA envelope (see FIG. 25) does 
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not match the displayed envelope. A logic flow diagram of an exemplary print configuration 
wizard is shown in FIG 33. Referring to FIG. 34, a test printer screen preferably prompts the 
user to place an envelope in the printer feed tray. The test printer screen advises the user that a 
sample envelope needs to be printed to determine whether the user's printer can print postal 
5 indicia and instructs the user to insert the envelope short edge first 183. When the user selects 
«Next>", a test pattern including, for example, a circle, a square, and a triangle may be printed 
1 86 (FIG. 33) on the envelope inserted into the printer. 

One of ordinary skill in the art will appreciate that the test pattern is not limited to the 
described combination of shapes. Rather the test pattern may comprise, for example, any 
10 combinationofshapes,symbols,letter S ornumbers. Alternatively, a single character may also 
be used wherein the printer offset may be determined in accordance with how the single 
character prints on a test envelope. Therefore, the described test pattern is by way of example 

and not by way of limitation. _ ■ 

The client software preferably draws all three shapes on a virtualized sheet. In an 
15 exemplary embodiment, only one of the shapes completely prints onto the envelope in 
accordance with how an envelope is fed into the printer. For example, in an exemplary 
embodiment a top feed printer (see FIG. 3 5) results in a circle being printed onto a test envelope, 
wherein a square pattern indicates a center feed printer (see FIG. 36) and a triangle pattern 
indicates a bottom feed printer (see FIG. 37). The top, center or bottom designauons are in 
20 reference to the location of the origin on the virtualized paper. . . . . 

Referring to FIG. 38, the system preferably asks the user to select which shape printed on 
the envelope 188 by for example, selecting one of a series of buttons 190, each of which 
corresponds to one ofthe particular shapes in the test pattern. Based upon this result, the system 
may determine the appropriate offset. Referring back to FIG. 33, the offset informauon may be 
25 sent to the server 192, and the user preferably continues with the insert envelope screen 128 
within the printer setup flow diagram shown in FIG. 25. 

If the user selects "none ofthe above match what I see" on FIG. 38, a trouble shoot screen 
1 94 may appear as shown in FIG. 39. The trouble shoot screen 194 preferably presents the user 
with a series of options and preferably prompts the user to select an option, by for example, 
30 selecting one ofa series dfbuttons, each ofwhich corresponds to a particular bpnon. Possible 

options may include for example: , , . A fMt 

Try printing another sample 1 96. If the user selects this option, a different test 
pattern is sent to me printer, so mat me comparison process may be undertaken 

again. . r . 

35 .Try printing another sample to a different printer 198. Selecting this option links 

the user back to the select default printer screen 121 of the print setup logic flow 
diagram (see FIG. 25), thus allowing the user to select another printer and start the 
process again. 
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I . Neither of these solutions work 200. Selecting this option intticates that the system 

cannot determine a feed offset and therefore cannot print envelopes using the user' s 
printer. 

If the user selects "neither of these solutions work" from the plurality of options on FIG. 
5 39,the system preferably informs the user that the current default printer does not support USPS 
requirements 202 and that the current printer is not able to print postage onto envelopes, only 
onto labels (see FIG. 40). A "Next^ button 204 may be immediately available. WhentheNext 
button 204 is selected, the client software preferably disables printing to envelopes 206 (see FIG. 
33). 

10 Although a preferred embodiment of the present invention has been described, it should 

not be construed to limit the scope of the appended claims. For example, the present invention 
may be implemented by a variety of computer based postage metering systems in accordance 
with a variety of print requirements promulgated by postal systems around the world. Further, 
although theoperation of the present invention has been demoMtratedm accordance with USPS 
15 requirements for PC based postal printing, the present invention is not limited to applications in 
accordance with the USPS requirements. Rather, the present invention is equally applicable for 
operation in all PC postal printing systems, 

In addition, those skilled in the art will understand that various modifications may be made 
to the described embodiment. Moreover, to those skilled in the various arts, the invention itself 
20 herein will suggest solutions to other tasks and adaptations for other applications. It is therefore 
desired that the present embodiments be considered in all respects as illustrative and not 
restrictive, reference being made to the appended claims rather than the foregoing description to 
indicate the scope of the invention. 
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1 WHAT IS CLAIMED IS: 

1. a method of printing postal indicia onto a print media comprising: 

determining a printer pfiset as a function of howthe print media is fed into a printer, and 
generating a print job for a viitualized sheet wherein an image of said postal indicia is 
5 located within a printable region of the virtuaiized sheet as a function of said printer offset 

2. The method of claim 1 further comprising printing said postal indicia onto said 
print media. 

10 3. The method of claim lfurther comprising detenruning size ofsaid virtuaiized sheet 

as a function of size of the print media. 

4. The method of claim 1 wherein the step of determining said printer offset comprises 
sending a print job having one or more patterns to said printer and determining said printer offset 

15 as a function of how one or more of said patterns prints on a test print media. 

5. The method of claim 1 wherein the step of determining said printer offset 

comprises: 

selecting a printer, and 

20 determining the printer offset for the printer from a printer database having information 

on one or more printer drivers. 

6. The method of claim 1 wherein the step of determining said printer offset 

comprises: 
25 selecting a printer; and 

determining the printer offset for the printer from a printer database having information 
on one or more printers. 

7. The method of claim 2 wherein the step of printing said postal indicia comprises 
30 printing a FIM. 

8. The method of claim 7 wherein the step of printing said FIM further comprises 
printing said F1M within a predefined distance of an edge of said envelope, 

35 9. The method of claim 7 wherein the step of printing said FIM further comprises 

printing said FIM within a distance of 0.125" of an edge of said envelope. 

10. The method of claim 2 wherein the step of printing said postal indicia comprises 
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printing a human readable portion. 

11. The method of claim 10 wherein the step of printing said human readable portion 
comprises printing a lpgo. 

12. The method of claim 1 1 further comprising scaling the logo as a function of said 
printable region of said virtualized sheet. 

13. The method of claim 2 wherein the step of printing said postal indicia comprises 
printing a two dimensional barcode portion. 

14. The method of claim 2 further comprising encoding a digital signature into a two 
dimensional barcode, wherein the step of printing said postal indica comprises printing said two 
dimensional bar code. 

15. The method of claim 1 further comprising rotating the image of said postal indicia 
as a function of the printable region of said virtualized sheet. 

16. The method of claim 1 5 further comprising translating an origin of said virtualized 
sheet and rendering the image of said postal indicia as a function of said translated origin. 

17. The method of claim 15 further comprising: 
performing a first set of adjustments to a drawing surface; 

rendering a first component of said postal indicia in accordance with the first set of 
adjustments to said drawing surface; 

storing location of a second component of said postal indicia in accordance with first set 
of adjustment to said drawing surface; 

performing a second set of adjustments to the drawing surface; and 

rendering said second component of said postal indicia in accordance with the second set 
of adjustments to the drawing surface. 

18. A method of printing postal indicia onto an envelope comprising: 
generating a print job for a virtualized sheet wherein an image of said postal indicia is 
located within a printable region of the virtualized sheet as a function of how said envelope is fed 

into a printer; 

performing a margins requirements test; and 

transmitting said print job to said printer to print said postal indicia as a function of said 
margin requirements test. 
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19. The method of claim 1 8 further comprising rotating said image as a function of said 
margin requirements test. 

20. Themethodof claim 1 9 furuher comprising translating an origm of said virn^ 
sheet and rendering said image of said envelope as a function of said translated origin. 

21. The method of claim 18 further comprising determining a printer offset as a 
function of how said envelope is fed into said printer, wherein said image of said envelppe is 
located in said printable region as a function of said printer offset 

22. The method of claim 21 wherein the step of determining said printer offset 
comprises sending a print job having one or more patterns to said printer and determining said 
printer offset as a function of how said pattern prints on a test envelope. 

23 . The method of claim 21 wherein the step of determining said printer offset 

comprises: 

selecting a printer; and 

determining the printer offset for the printer from a printer database having information 
on one or more printer drivers. 

24. The method of claim 1 8 wherein the step of printing said postal indicia comprises 
. printing a FIM. 

25. The method of claim 24 wherein the step of printing said FIM further comprises 
printing said FIM within a predefined distance of an edge of said envelope. 

26. The method of claim 18 the step of printing said postal indicia comprises printing 
a human readable portion. 

27. The method of claim 26 wherein the step of printing said human readable portion 
comprises printing a logo. 

28. The method of claim 27 further comprising scaling the logo as a function of said 
printable region of said virtualized sheet. 

29. The method of claim 1 8 wherein the step of printing said postal indicia comprises 
priming a two dimensional barcode portion. 
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30 A method of printing onto a print media comprising: 

generating a print job for a virtualized sheets wherein an image to printed on said print 
media is located within a printable region of said virtualized sheet as a function of printing said 
image closer to one or more edges of said print media than otherwise allowed by a printer for said 
print media. 

3 1 . The method of claim 30 further comprising printing said image onto said print 

media. 

32. The method of claim 30 further comprising determining size of said virtualized 
sheet as a function of size of the print media. 

33. The method of claim 30 further comprising determining a printer offset as a 
function of how said print media feeds into said printer, wherein said image is located within said 
printable region of said virtualized sheet as a function of said offset 

34. The method of claim 33 wherein the step of determining said printer offset 
comprises sending a print job having one or more patterns to said printer and deternuning said 
printer offset as a function of how one or more of said patterns prints on a test print media 

35. The method of claim 33 wherein the step of determining said printer offset 

comprises: 

selecting a printer; and 

determining the printer offset for the printer from a printer database having information 
on one or more printer drivers. 

36. The method of claim 3 1 wherein the step of printing said image comprises printing 
a postal indicia. 

37. The method of claim 36 wherein the step of printing said postal indicia further 
comprises printing a FIM within a predefined distance of an edge of said envelope. 

38. The method of claim 30 further comprising rotating the image as a function of the 
printable region of said virtualized sheet. 

39. The method ofclaim 38 further comprising translating an origin of said virtualized 
sheet and rendering the image as a ruction of said translated origin. 
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40 The method of claim 38 further comprising: 
performing a first set of adjustments to a drawing surface; 

rendering a first component of said image in accordance with thefirst set of adjustments 
to said drawing surface; 

storing location of a second component of said image in accordance with first set of 

adjustment to said drawing surface; 

performing a second set of adjustments to the drawing surface; and 

rendering said second component of said image in accordance with the second set of 

adjustments to the drawing surface, 

41. A system for printing postal indicia comprising: 

means for determining a printer offset as a function of how an envelope is fed into said 
printer; 

means for generating a print job for a virtualized sheet, wherein an image of said postal 
indicia is located within a printable region of the virtualized sheet as a function of said printer 
offset; and 

a printer for printing said postal indicia onto said envelope. 

42. The system of claim 41 further comprising means for determining size of the 
virtualized sheet as a function of size of the envelope. 

43. The system of claim 41 wherein the means for determining said printer offset 
comprises means for sending a print job having one or more patterns to said printer and means 
for determining said printer offset as a function of how said one or more patterns print on a test 
envelope. 

44. The system of claim 41 wherein the means for determining said printer offset 

comprises: 

means for selecting a printer; 

means for determining the offset for said printer from a printer database having 
information on one or more printer drivers. 

45 . The system of claim 4 1 further comprising means for rotating the image of said 
postal indicia as a function of said printable region of said virtualized sheet. 

46. The system of claim 4 1 further comprising means for scaling a logo as a function 
of said printable region of said virtualized sheet. 
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1 47. Computer-readable media embodying a program of instructions executable by a 

computer to perform a method for printing postal indicia onto an envelope, the method 
comprising: 

determining a printer offset as a function of how the envelope is fed into said printer, 
5 generating a print job for a virtualized sheet wherein an image of said postal indicia is 

located within a printable region of the virtualized sheet as a function of said printer offset; and 
printing said postal indicia onto said envelope. 

48. The computer-readable media of claim 47 further comprising determining size of 
10 the virtualized sheet as a function of size of the envelope. 

49. The computer-readable media of claim 47 wherein the step of determining said 
printer offset comprises sending a print job having one or more patterns to said printer and 
determining said printer offset as a function of how said patterns print on a test envelope. 

15 

50. The computer-readable media of claim 47 wherein the step of determining said 
printer offset comprises: 

selecting a printer; 

determining the offset for the selected printer from a printer database having information 
20 on one or more printer drivers. 

51. The computer-readable media of claim 47 wherein the step of printing said postal 
indicia comprises printing a FIM 

25 52. The computer-readable media of claim 47 wherein the step of printing said postal 

indicia comprises printing a human readable portion. 

53 . The computer-readable media of claim 52 wherein the step of printing said human 
readable portion comprises printing a logo. 

■ 30 

54. The computer-readable media of claim 53 further comprising scaling the logo as 
a function of said printable region of said virtualized sheet. 

55. The computer-readable media of claim 47 wherein the step of printing said postal 
35 indicia comprises printing a two dimensional barcode portion. 

56. The computer-readable media of claim 47 further comprising rotating the image 
of said envelope as a function of printable region of said virtualized sheet. 
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[ 57. The computer-readable media of claim 56 further comprising translating an origin 

of said virtualized sheet and rendering the image of said postal indicia as a function of said 
translated origin. 

5 5g. The computer-readable media of claim 56 further comprising: 

performing a first set of adjustments to a drawing surface; 

rendering a first component of said graphic in accordance with the first set of adjustments 

to said drawing surface; 

storing location of a second component of said graphic in accordance with first set of 

10 adjustment to said drawing surface; 

performing a second set of adjustments to the drawing surface; and 
rendering said second component of said graphic in accordance with the second set of 
adjustments to the drawing surface. 

15 
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